### <u>Unit-5</u> <u>Combinational logic with MSI and LSI</u>

For more notes visit:

https://collegenote.pythonanywhere.com/

https://collegenote.pythonanywhere.com

#### <u>Unit-5</u> Combinational Logic with MSI and LSI

#### **Binary Adder**

This circuit sums up two binary numbers *A* and *B* of n-bits using full-adders to add each bit pair and carry from previous bit position.

#### **Binary Parallel Adder:**

A binary parallel adder is a digital circuit that produces the arithmetic sum of two binary numbers in parallel. It consists of full adders connected in cascade, with the output carry from one full adder connected to the input carry of the next full adder. An n bit parallel adder requires n full adders.

#### 4-bit binary parallel adder:



Fig: 4-bit binary parallel adder

A 4-bit binary parallel adder consists of 4-full adder. The augend bits are  $A_4$ ,  $A_3$ ,  $A_2$ ,  $A_1$  and addend bits are  $B_1$ ,  $B_2$ ,  $B_3$ ,  $B_4$ . This parallel adder produces their sum as  $C_4S_3S_2S_1S_0$  where  $C_4$  is the final carry. The carries are connected in chain through the full-adders. The input carry to the first full adder is  $C_1$  and the output carry from MSB position of full adder is  $C_4$ .

#### **Q. Design a BCD-to-excess-3 code converter using a 4-bit full adders MSI circuit.** Sol<sup>n</sup>:

 $Excess - 3 \ code = BCD \ code + (0011)_2$ 

Augend bits = 
$$X_4 X_3 X_2 X_1$$
 (Input bits)

Addend bits =  $Y_4 Y_3 Y_2 Y_1 = 0011$ 

Excess-3 code =  $S_4 S_3 S_2 S_1$  (output)



https://collegenote.pythonanywhere.com

#### Decimal adder/BCD adder:

BCD adder is a combinational digital circuit that adds two BCD digits in parallel and produces sum which is also BCD.

- In BCD adder, each input digit does not exceed 9, so the output sum can't be greater than 9 + 9 + 1 = 19, the 1 in the sum being an input carry.
- Suppose we apply two BCD digits to a 4-bit binary adder. The adder will form the sum in binary and produce a result which may range from 0 to 19.

| Decima |            | BCD Sum |            |            |   | m          | nary Su        | Bir |            |   |
|--------|------------|---------|------------|------------|---|------------|----------------|-----|------------|---|
|        | <b>S</b> 1 | S2      | <b>S</b> 4 | <b>S</b> 8 | c | <b>Z</b> 1 | Z <sub>2</sub> | Z4  | <b>Z</b> 8 | ĸ |
| 0      | 0          | 0       | 0          | 0          | 0 | 0          | 0              | 0   | 0          | 0 |
| 1      | 1          | 0       | 0          | 0          | 0 | 1          | 0              | 0   | 0          | 0 |
| 2      | 0          | 1       | 0          | 0          | 0 | 0          | 1              | 0   | 0          | 0 |
| 3      | 1          | 1       | 0          | 0          | 0 | 1          | 1              | 0   | 0          | 0 |
| 4      | 0          | 0       | 1          | 0          | 0 | 0          | 0              | 1   | 0          | 0 |
| 5      | 1          | 0       | 1          | 0          | 0 | 1          | 0              | 1   | 0          | 0 |
| 6      | 0          | 1       | 1          | 0          | 0 | 0          | 1              | 1   | 0          | 0 |
| 7      | 1          | 1       | 1          | 0          | 0 | 1          | 1              | 1   | 0          | 0 |
| 8      | 0          | 0       | 0          | 1          | 0 | 0          | 0              | 0   | 1          | 0 |
| 9      | 1          | 0       | 0          | 1          | 0 | 1          | 0              | 0   | 1          | 0 |
| 10     | 0          | 0       | 0          | 0          | 1 | 0          | 1              | 0   | 1          | 0 |
| 11     | 1          | 0       | 0          | 0          | 1 | 1          | 1              | 0   | 1          | 0 |
| 12     | 0          | 1       | 0          | 0          | 1 | 0          | 0              | 1   | 1          | 0 |
| 13     | 1          | 1       | 0          | 0          | 1 | 1          | 0              | 1   | 1          | 0 |
| 14     | 0          | 0       | 1          | 0          | 1 | 0          | 1              | 1   | 1          | 0 |
| 15     | 1          | 0       | 1          | 0          | 1 | 1          | 1              | 1   | 1          | 0 |
| 16     | 0          | 1       | 1          | 0          | 1 | 0          | 0              | 0   | 0          | 1 |
| 17     | 1          | 1       | 1          | 0          | 1 | 1          | 0              | 0   | 0          | 1 |
| 18     | 0          | 0       | 0          | 1          | 1 | 0          | 1              | 0   | 0          | 1 |
| 19     | 1          | 0       | 0          | 1          | 1 | 1          | 1              | 0   | 0          | 1 |

Truth table for BCD adder is:

- In examining the content of the table, it is apparent that when the binary sum is equal to or less than 1001, the corresponding BCD number is identical, and therefore no conversion is needed.
- When the binary sum is greater than 1001, we obtain a non-valid BCD representation. The addition of binary 0110 (6 in decimal) to the binary sum converts it to the correct BCD representation and also produces an output carry.
- It is obvious from the table that a correction is needed when the binary sum has an output carry k = 1.
- The other six combination from 1010 to 1111 that need a correction have a 1 in position  $Z_8$ . To distinguish them from binary 1000 and 1001, which also have a 1 in position  $Z_8$ , we specify further that either  $Z_4$  or  $Z_2$  must have 1.
- The condition for a correction and an output carry can be expressed by the Boolean function:  $C = K + Z_8 Z_4 + Z_8 Z_2$
- When output carry C = 0, nothing is added to the binary sum.

- When output carry C = 1, binary 0110 is added to the binary sum through the bottom 4bit binary adder to convert the binary sum into BCD sum. (*In fig. below*)



#### **Magnitude** Comparator

A magnitude comparator is a combinational circuit that compares two numbers A & B and determines their relative magnitudes. The outcome of the comparison is specified by three binary variables that indicate whether A > B, A = B, or A < B.



*Note:* Out of these three outputs only one output will be 1 and other two outputs will be 0 at a time.

#### 4-bit magnitude comparator:

4-bit magnitude comparator is a combinational logic circuit that compares two binary numbers each of 4-bits.

Consider two numbers A & B with four digits each.

$$A = A_3 A_2 A_1 A_0$$
$$B = B_3 B_2 B_1 B_0$$

#### *Verification of* (A = B)*:*

- The equality relation of each pair of bits can be expressed:

 $x_i = A_i B_i + \overline{A_i} \overline{B_i}, \quad i = 0, 1, 2, 3$ Where  $x_i = 1$  only if  $A_i = B_i$  and  $x_i = 0$  only if  $A_i \neq B_i$ .

- For equality condition to exist, all  $x_i$  variables must be equal to 1. A & B will be equal if  $x_3x_2x_1x_0 = 1$ .

$$\therefore (A = B) = x_3 x_2 x_1 x_0$$

#### Verification of (A > B):

- If  $A_3 > B_3$  then A > B, it means  $A_3 = 1 \& B_3 = 0$ . Therefore A is greater than B if  $A_3\overline{B}_3 = 1$ .
- If  $A_3 = B_3(i.e x_3 = 1)$  and  $A_2 > B_2$  then A > B. Therefore A is greater than B if  $x_3A_2\overline{B}_2 = 1$ .
- If  $A_3 = B_3(i.e x_3 = 1) \& A_2 = B_2(i.e x_2 = 1)$  and  $A_1 > B_1$  then A > B. Therefore A is greater than B if  $x_3x_2A_1\overline{B}_1 = 1$ .
- If  $A_3 = B_3(i.e x_3 = 1) \& A_2 = B_2(i.e x_2 = 1) \& A_1 = B_1(i.e x_1 = 1) \text{ and } A_0 > B_0$ then A > B. Therefore A is greater than B if  $x_3x_2x_1A_0\overline{B}_0 = 1$ .

$$\therefore (A > B) = A_3\overline{B}_3 + x_3A_2\overline{B}_2 + x_3x_2A_1\overline{B}_1 + x_3x_2x_1A_0\overline{B}_0$$

In the same manner we can derive the expression for (A < B).

$$\therefore (A > B) = \overline{A}_3 B_3 + x_3 \overline{A}_2 B_2 + x_3 x_2 \overline{A}_1 B_1 + x_3 x_2 x_1 \overline{A}_0 B_0$$

https://collegenote.pythonanywhere.com

Logic Diagram:



Fig. 4-17 4-Bit Magnitude Comparator

#### **Decoders**

A decoder is a combinational circuit that converts binary information from n input lines to a maximum of  $2^n$  unique output lines.

- If *n*-bit decoded information has unused or don't care combinations, the decoder output will have less than  $2^n$  outputs.
- The decoders presented here are called n to m line decoders where  $m \le 2^n$ . Their purpose is to generate the  $2^n$  (or less) minterms of n input variables.



#### <u>3-to-8 line decoder:</u>

The three inputs are decoded into eight outputs, each output representing one of the minterms of the 3-input variables.

A particular application of this decoder would be a binary-to-octal conversion. The input variable may represent a binary number and the outputs will then represent the eight digits in the octal number system

Three inputs: X, Y & ZEight outputs:  $D_0 - D_7$ 



Fig: 3-to-8 line decoder

| 1 | npu | ts | Outputs        |                |                |                |                |    |                |                |
|---|-----|----|----------------|----------------|----------------|----------------|----------------|----|----------------|----------------|
| X | Y   | Z  | D <sub>0</sub> | D <sub>1</sub> | D <sub>2</sub> | D <sub>3</sub> | D <sub>4</sub> | D5 | D <sub>6</sub> | D <sub>7</sub> |
| 0 | 0   | 0  | 1              | 0              | 0              | 0              | 0              | 0  | 0              | 0              |
| 0 | 0   | 1  | 0              | 1              | 0              | 0              | 0              | 0  | 0              | 0              |
| 0 | 1   | 0  | 0              | 0              | 1              | 0              | 0              | 0  | 0              | 0              |
| 0 | 1   | 1  | 0              | 0              | 0              | 1              | 0              | 0  | 0              | 0              |
| 1 | 0   | 0  | 0              | 0              | 0              | 0              | 1              | 0  | 0              | 0              |
| 1 | 0   | 1  | 0              | 0              | 0              | 0              | 0              | 1  | 0              | 0              |
| 1 | 1   | 0  | 0              | 0              | 0              | 0              | 0              | 0  | 1              | 0              |
| 1 | 1   | 1  | 0              | 0              | 0              | 0              | 0              | 0  | 0              | 1              |

From the truth table it is observed that the output variables are mutually exclusive because only one output can be equal to 1 at any one time. The output line whose value is equal to 1 represents the minterm equivalent of the binary number presently available in the input lines.

https://collegenote.pythonanywhere.com

Truth table:

#### *Q. Implement a full-adder circuit with a decoder and two OR gates.* Sol<sup>n</sup>:

The truth table for full adder:

|   | Input |   | Out | put   |
|---|-------|---|-----|-------|
| Α | B Cir |   | Sum | Carry |
| 0 | 0     | 0 | 0   | 0     |
| 0 | 0     | 1 | 1   | 0     |
| 0 | 1     | 0 | 1   | 0     |
| 0 | 1     | 1 | 0   | 1     |
| 1 | 0     | 0 | 1   | 0     |
| 1 | 0     | 1 | 0   | 1     |
| 1 | 1     | 0 | 0   | 1     |
| 1 | 1     | 1 | 1   | 1     |

#### From the truth table

 $S(A, B, C_{in}) = \sum (1, 2, 4, 7)$ 

 $C(A, B, C_{in}) = \sum (3, 5, 6, 7)$ 

Since there are three inputs and a total of eight minterms. So we need 3-to-8 line decoder. The decoder generates the eight minterms for  $A, B \& C_{in}$ . The OR gate for output sum (S) forms the sum of minterms 1, 2, 4 & 7. The OR gate for the output carry (C) forms the sum of minterms 3, 5, 6 & 7.



Fig: Full adder implementation with decoder

#### Encoder

An encoder is a combinational circuit that performs the inverse operation from that of decoder. It has  $2^n$  input lines and n output lines.

The output lines generate the binary code corresponding to the input value.



Fig: Block diagram of encoder

#### E.g. Octal to binary encoder which has 8 inputs and 3 outputs.

Truth table for octal to binary encoder:

|                |   |                | INF            | PUT            |                |                |                | C | UTPU | Т |
|----------------|---|----------------|----------------|----------------|----------------|----------------|----------------|---|------|---|
| D <sub>0</sub> | D | D <sub>2</sub> | D <sub>3</sub> | D <sub>4</sub> | D <sub>5</sub> | D <sub>6</sub> | D <sub>7</sub> | Х | Y    | Z |
| 1              | 0 | 0              | 0              | 0              | 0              | 0              | 0              | 0 | 0    | 0 |
| 0              | 1 | 0              | 0              | 0              | 0              | 0              | 0              | 0 | 0    | 1 |
| 0              | 0 | 1              | 0              | 0              | 0              | 0              | 0              | 0 | 1    | 0 |
| 0              | 0 | 0              | 1              | 0              | 0              | 0              | 0              | 0 | 1    | 1 |
| 0              | 0 | 0              | 0              | 1              | 0              | 0              | 0              | 1 | 0    | 0 |
| 0              | 0 | 0              | 0              | 0              | 1              | 0              | 0              | 1 | 0    | 1 |
| 0              | 0 | 0              | 0              | 0              | 0              | 1              | 0              | 1 | 1    | 0 |
| 0              | 0 | 0              | 0              | 0              | 0              | 0              | 1              | 1 | 1    | 1 |

Boolean function of output variables:

 $X = D_4 + D_5 + D_6 + D_7$   $X = D_2 + D_3 + D_6 + D_7$  $X = D_1 + D_3 + D_5 + D_7$ 

Logic circuit:



*Limitation:* Only one input can be enabled at a time. If two inputs are enabled at the same time, then output is undefined.

*Q. Design a 3 to 8 line decoder using two 2 to 4 line decoder and explain it. Sol<sup>n</sup>:* 



Fig: 3 to 8 decoder using two 2 to 4 decoder

The figure shows two  $2 \times 4$  decoder with enable input (E) connected to form a  $3 \times 8$  decoder. When E = 0, the top decoder is enabled and the other is disabled. The bottom decoder outputs are all 0's and the top four outputs generate minterms 000 to 001. When E = 1, the enable conditions are reversed. The bottom decoder outputs generate minterms 100 to 111 while the outputs of the top decoder are all 0's.

#### *Q. Design a 2-to-4 line decoder using NAND gates.* Sol<sup>n</sup>:



Truth table:

| Inp | uts | Outputs |       |       |       |  |  |
|-----|-----|---------|-------|-------|-------|--|--|
| Α   | В   | $D_0$   | $D_1$ | $D_2$ | $D_3$ |  |  |
| 0   | 0   | 0       | 1     | 1     | 1     |  |  |
| 0   | 1   | 1       | 0     | 1     | 1     |  |  |
| 1   | 0   | 1       | 1     | 0     | 1     |  |  |
| 1   | 1   | 1       | 1     | 1     | 0     |  |  |

For the NAND decoder only one output can be LOW and equal to logic '0' at any given time with all other outputs being HIGH at logic '1'.

*Note:* Similar method for 3-to-8 line decoder in which 3-lines of input are present and 8 output lines.

**Q.** Using a decoder and external gates, design the combinational circuit defined by the following three Boolean functions:

$$F_1 = x'y'z + xz'$$
  

$$F_2 = x'yz' + xy'$$
  

$$F_3 = xyz' + xy$$

Sol<sup>n</sup>:



#### Multiplexer (MUX)

- A multiplexer is a combinational circuit that selects binary information from one of many input lines and directs it to a single output line.
- Multiplexing is the process of transmitting a large number of information over a single line.
- The selection of a particular input lines is controlled by a set of selection lines. Normally there are  $2^n$  input lines and n selection lines whose bit combinations determine which input is selected.
- A multiplexer is also called a data selector, since it selects one of many inputs and steers the binary information to the output line.



#### <u>4-to-1 line Multiplexer:</u>



#### Q. Design a 8-to-1 line multiplexer using lower order multiplexers and explain it.





The same **selection lines**,  $s_1 \& s_0$  are applied to both 4x1 Multiplexers. The data inputs of upper 4x1 Multiplexer are  $I_0$  to  $I_3$  and the data inputs of lower 4x1 Multiplexer are  $I_4$  to  $I_7$ . Therefore, each 4x1 Multiplexer produces an output based on the values of selection lines,  $s_1 \& s_0$ .

The outputs of first stage 4x1 Multiplexers are applied as inputs of 2x1 Multiplexer that is present in second stage. The other **selection line**,  $s_2$  is applied to 2x1 Multiplexer.

- If  $s_2$  is zero, then the output of 2x1 Multiplexer will be one of the 4 inputs  $I_0$  to  $I_3$  based on the values of selection lines  $s_1 \& s_0$ .
- If  $s_2$  is one, then the output of 2x1 Multiplexer will be one of the 4 inputs I<sub>4</sub> to I<sub>7</sub> based on the values of selection lines  $s_1 \& s_0$ .

Therefore, the overall combination of two 4x1 Multiplexers and one 2x1 Multiplexer performs as one 8x1 Multiplexer.

#### **Q.** Implement the Boolean function $F(A, B, C) = \sum (1, 3, 5, 6)$ with multiplexer.

#### Sol<sup>n</sup>:

The multiplexer can be implemented with 4 to 1 multiplexer.

*Note:* It is possible to generate n+1 variables with  $2^n$  to 1 mutiplexer.

Now, truth table for the given function is:

|         |   | - 0 |   |   |
|---------|---|-----|---|---|
| Minterm | A | ₿   | С | F |
| 0       | 0 | 0   | 0 | 0 |
| 1       | 0 | 0   | 1 | 1 |
| 2       | 0 | 1   | 0 | 0 |
| 3       | 0 | 1   | 1 | 1 |
| 4       | 1 | 0   | 0 | 0 |
| 5       | 1 | 0   | 1 | 1 |
| 6       | 1 | 1   | 0 | 1 |
| 7       | 1 | 1   | 1 | 0 |
|         |   |     |   |   |

Now the implementation table is

|    | I <sub>0</sub> | $I_1$   | $I_2$ | 13 |
|----|----------------|---------|-------|----|
| A' | 0              | $\odot$ | 2     | 3  |
| А  | 4              | 3       | 6     | 7  |
|    | 0              | 1       | Α     | A' |

- If the minterms in a column are not circled, then apply 0 to the corresponding multiplexer unit.
- If the 2 minterms are circled, then apply 1 to the corresponding multiplexer unit.
- If the bottom minterm is circled, and top is not circled then apply *A* to the corresponding multiplexer unit.
- If the top minterm is circled, and bottom is not circled then apply A' to the corresponding multiplexer unit.

Multiplexer implementation:



## **Q.** Implement the Boolean function $F(A, B, C, D) = \sum (0, 1, 3, 4, 8, 9, 15)$ by multiplexer. Sol<sup>n</sup>:

This function can be implemented with 8 to 1 MUX. The truth table for the function is

| Minterm | Α | B | С | D | F |
|---------|---|---|---|---|---|
| 0       | 0 | 0 | 0 | 0 | 1 |
| 1       | 0 | 0 | 0 | 1 | 1 |
| 2       | 0 | 0 | 1 | 0 | 0 |
| 3       | 0 | 0 | 1 | 1 | 1 |
| 4       | 0 | 1 | 0 | 0 | 1 |
| 5       | 0 | 1 | 0 | 1 | 0 |
| 6       | 0 | 1 | 1 | 0 | 0 |
| 7       | 0 | 1 | 1 | 1 | 0 |
| 8       | 1 | 0 | 0 | 0 | 1 |
| 9       | 1 | 0 | 0 | 1 | 1 |
| 10      | 1 | 0 | 1 | 0 | 0 |
| 11      | 1 | 0 | 1 | 1 | 0 |
| 12      | 1 | 1 | 0 | 0 | 0 |
| 13      | 1 | 1 | 0 | 1 | 0 |
| 14      | 1 | 1 | 1 | 0 | 0 |
| 15      | 1 | 1 | 1 | 1 | 1 |

Now the implementation table and multiplexer implementation are given below:



#### **Demultiplexer (DEMUX)**

- A decoder with an enable input can function as a de-multiplexer.
- A de-multiplexer is a circuit that **receives information on a single line** and transmit this information on one of  $2^n$  **possible output lines**. The selection for particular output line is controlled by the bit values of *n* selection lines.



Fig: A 2-to-4 line decoder with enable (E) input

The decoder of fig can function as a de-multiplexer if the E line is taken as a data input line and lines A and B are taken as the selection lines.



#### 1 to 4 DEMUX:

The 1:4 Demux consists of 1 data input bit, 2 control bits and 4 output bits. I is the input bit,  $Y_0$ ,  $Y_1$ ,  $Y_2$ ,  $Y_3$  are the four output bits and  $S_0$  and  $S_1$  are the control bits.





| $S_1 S_{\theta}$ | Y <sub>3</sub> | <b>Y</b> 2 | Y | Y |
|------------------|----------------|------------|---|---|
| 0 0              | 0              | 0          | 0 | Ι |
| 0 1              | 0              | 0          | Ι | 0 |
| 1 0              | 0              | Ι          | 0 | 0 |
| 1 1              | Ι              | 0          | 0 | 0 |

1 to 8 De-Multiplexer using 1x4 De-Multiplexers and 1x2 De-Multiplexer:



The common **selection lines, s<sub>1</sub> & s<sub>0</sub>** are applied to both 1x4 De-Multiplexers. The outputs of upper 1x4 De-Multiplexer are  $Y_7$  to  $Y_4$  and the outputs of lower 1x4 De-Multiplexer are  $Y_3$  to  $Y_0$ .

The other **selection line**,  $s_2$  is applied to 1x2 De-Multiplexer. If  $s_2$  is zero, then one of the four outputs of lower 1x4 De-Multiplexer will be equal to input, I based on the values of selection lines  $s_1 \& s_0$ . Similarly, if  $s_2$  is one, then one of the four outputs of upper 1x4 De-Multiplexer will be equal to input, I based on the values of selection lines  $s_1 \& s_0$ .

#### **MUX-DEMUX Application Example**



- This enables sharing a single communication line among a number of devices.
- At any time, only one source and one destination can use the communication line.

#### Read Only Memory (ROM)

- A read-only memory (ROM) is a device that includes both the decoder and the OR gates within a single IC package. The connections between the outputs of the decoder and the inputs of the OR gates can be specified for each particular configuration by "programming" the ROM.
- A ROM is essentially a memory (or storage) device in which a fixed set of binary information is stored.
- The binary information must first be specified by the user and is then embedded in the unit to form the required interconnection pattern. ROM's come with special internal links that can be fused or broken. The desired interconnection for a particular application requires that certain links be fused to form the required circuit paths. Once a pattern is established for a ROM, it remain fixed even when power is turned off and then on again.
- A ROM consists of *n* input lines and *m* output lines.
- Each bit combination of input variables is called an address.
- Each bit combination that comes out of the output lines is called a word. The number of bits per word is equal to the number of output lines m.
- A ROM with n input lines has  $2^n$  distinct addresses, so there are  $2^n$  distinct words which are said to be stored in the unit.



Internally, the ROM is a combinational circuit with AND gates connected as a decoder and a number of OR gates equal to the number of outputs in the unit.

#### **Combinational Logic implementation of ROM:**

When a combinational circuit is implemented by means of ROM the function must be expressed in sum of min terms or better yet by a truth table.

**Q.** Implement the following combinational logic function with a 4X2 ROM.

| <b>A</b> <sub>1</sub> | $A_0$ | $F_1$ | $F_2$ |
|-----------------------|-------|-------|-------|
| 0                     | 0     | 0     | 1     |
| 0                     | 1     | l     | 0     |
| 1                     | 0     | 1     | 1     |
| 1                     | l     | 1     | 0     |

Sol<sup>n</sup>:

Truth table specifies a combinational circuit with 2 inputs and 2 outputs. The Boolean function can be represented in SOP as;

 $F_1(A_1, A_0) = \Sigma(1, 2, 3)$  $F_2(A_1, A_0) = \Sigma(0, 2)$ 

Combinational-circuit implementation with a 4 x 2 ROM:



# Q. Design a combinational circuit using a ROM. The circuit accepts a 3-bit number and generates an output binary number equal to the square of the input number. Sol<sup>n</sup>:

| First step | is to | derive the | e truth | table | for | the | combinational | circuit |
|------------|-------|------------|---------|-------|-----|-----|---------------|---------|
| 1          |       |            |         |       |     |     |               |         |

|    | Inputs |       |                       |         |                |                       |    |                       |         |
|----|--------|-------|-----------------------|---------|----------------|-----------------------|----|-----------------------|---------|
| A, | A1     | $A_0$ | <i>B</i> <sub>5</sub> | $B_{1}$ | B <sub>3</sub> | <i>B</i> <sub>2</sub> | В, | <i>B</i> <sub>0</sub> | Decimal |
| 0  | 0      | 0     | 0                     | 0       | 0              | 0                     | 0  | 0                     | 0       |
| 0  | 0      | 1     | õ                     | Ő       | 0              | 0                     | 0  | 1                     | 1       |
| 0  | 1      | 0     | ŏ                     | Ō       | 0              | 1                     | 0  | 0                     | 4       |
| 0  | 1      | Ĭ     | ŏ                     | ŏ       | 1              | 0                     | 0  | 1                     | 9       |
| 0  | 1      | 1     | ň                     | Ť       | 0              | 0                     | 0  | 0                     | 16      |
| 1  | 0      | 1     | 0                     | 1       | ĭ              | 0                     | 0  | 1                     | 25      |
| 1  | 0      | 1     | 1                     | ò       | 0              | 1                     | 0  | 0                     | 36      |
| ł  | 1      | 1     | 1                     | 1       | ň              | Ô                     | Ő  | 1                     | 49      |
| 1  | 1      | 1     | 1                     | 1       | 0              |                       |    | I                     |         |

Output  $B_0$  is always equal to input  $A_0$ ; so there is no need to generate  $B_0$  with a ROM since it is equal to an input variable. Moreover, output B1 is always 0, so this outputs is always known.

Implementation by ROM:



| $A_2$ | $A_1$ | $A_0$ | $F_1$ | $F_2$ | $F_3$ | $F_4$ |
|-------|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0     | 0     | 1     | 0     | 0     | 0     | 0     |
| 0     | 1     | 0     | 0     | 0     | 0     | l     |
| 0     | 1     | 1     | 0     | 0     | 1     | 0     |
| 1     | 0     | 0     | 0     | 1     | 0     | 0     |
| 1     | 0     | 1     | 0     | 1     | 1     | 0     |
| 1     | 1     | 0     | 1     | 0     | 0     | 1     |
| 1     | 1     | 1     | 1     | 1     | 0     | 0     |

#### (a) Block diagram

#### (b) ROM truth table

#### Types of ROM:

#### 1. Mask ROM

- Permanent programming done at fabrication time
- Fabrication take place at factory as per customer order
- Very expensive and therefore feasible only for large quantity orders
- Once the memory is programmed during the manufacturing process, the user cannot alter the programs.

#### 2. PROM (Programmable ROM)

- A blank chip which can be programmed only once using a special device called programmer.
- Once it's programmed its content cannot be modified or erased.

#### 3. EPROM (Erasable Programmable ROM)

- Can be programmed multiple times.
- Its content can be erased by using UV (ultra violet) light.
- Exposure to the UV light will erase all contents.

#### 4. EEPROM (Electrically Erasable Programmable ROM)

- Similar to EPROM but its contents can be electrically erased and re-written without having to remove it from the computer.

#### Programmable Logic Array (PLA)

A combinational circuit may occasionally have don't care conditions. When implemented with a ROM, a don't care condition becomes an address input that will never occur. The words at the don't care addresses need not be programmed and may be left in their original state (all 0's or all 1's). The result is that not all the bit patterns available in the ROM are used, which may be considered as waste of available equipment.

**For example**, a combinational circuit that converts a 12-bit card code to a 6-bit internal alphanumeric code.

\* It consists 12 inputs and 6 outputs. The size of the ROM must be  $4096 \times 6 (2^{12} \times 6)$ .

\* There are only 47 valid entries for the card code, all other input combinations are don't care. The remaining 4049 words of ROM are not used and are thus wasted.

*So, Programmable Logic Array* is a LSI component that can be used in economically as an alternative to ROM where number of don't-care conditions is excessive.

✓ PLA does not provide full decoding of the variables and does not generate all the minterms as in the ROM.

#### <u>Block diagram of PLA:</u>

A block diagram is shown in fig. It consists n inputs, m-outputs, k product terms and m sum terms. The product terms constitute a group of k AND gates and the sum terms constitute a group of m OR gates.



✓ The number of programmed links is  $2n \times k + k \times m + m$ , whereas that of a ROM is  $2^n \times m$ .

#### Implementation of combinational circuit by PLA:

 $F_1 = AB' + AC$  $F_2 = AC + BC$ 

PLA program table:

| Product | Inputs |   |   | Outputs |       | 1=uncomplemented in ter     |
|---------|--------|---|---|---------|-------|-----------------------------|
| term    | A      | B | C | $F_1$   | $F_2$ | 0=complemented in term      |
| 1       | 1      | 0 |   | 1       | _     | - = does not participate    |
| 2       | 1      | - | 1 | 1       | 3     | Output side:                |
| 3       | -      | 1 | 1 |         | 1     | 1 = term connected to outp  |
|         |        |   |   | T       | Т     | - = no connection to output |







PLA program table consists of three columns:

- *First column:* lists the product terms numerically.
- Second column: specifies the required paths between inputs and AND gates.
- *Third column:* specifies the paths between the AND gates and the OR gates.

Under each output variable, we write a T (for true) if the output inverter is to be bypassed, and C (for complement) if the function is to be complemented with the output inverter.

*Note:* PLA implements the functions in their sum of products form (standard form, not necessarily canonical as with ROM). Each product term in the expression requires an AND gate. It is necessary to simplify the function to a minimum number of product terms in order to minimize the number of AND gates used.

#### **Q.** A combinational circuit is defined by the functions:

 $F_1(A, B, C) = \sum (3, 5, 6, 7)$ 

$$F_2(A, B, C) = \sum (0, 2, 4, 7)$$

Implement the circuit with a PLA having three inputs, four product terms, and two outputs.

Sol<sup>n</sup>:

First of all we have to write the function in minimize SOP form:



There are six product terms in  $F_1$  and  $F_2$ , but only four product terms are allowed to use. Now implement  $F'_1(A, B, C)$ 

$$F'_1(A, B, C) = \sum (0, 1, 2, 4)$$
  

$$F_2(A, B, C) = \sum (0, 2, 4, 7)$$

From these equation it is clear that the minterms 0, 2 and 4 are common. Now obtain the minimized expression by using them



Now four product terms are B'C', A'C', A'B' and ABC.

$$F_1 = B'C' + A'C' + A'B'$$
  

$$F_2 = B'C' + ABC + A'C'$$

Now, PLA program table:

| 1    | Product | Inputs |   |   | Outputs |       |     |
|------|---------|--------|---|---|---------|-------|-----|
| 1    | term    | A      | В | С | F1      | $F_2$ |     |
| B'C' | 1       | -      | 0 | 0 | 1       | 1     | 1   |
| A'C' | 2       | 0      |   | 0 | 1       | 1     |     |
| A'B' | 3       | 0      | 0 | _ | 1       | _     |     |
| ABC  | 4       | 1      | 1 | 1 | -       | 1     |     |
|      |         |        |   |   | С       | Τ     | T/C |

Note that output  $F_1$  is the normal (or true) output even though a C is marked under it. This is because  $F'_1$  is generated prior to the output inverter. The inverter complements the function to produce  $F_1$  in the output.

Draw PLA circuit yourself.